package com.whc.gulimall.ware.dao;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.whc.common.to.SkuHasStockVo;
import com.whc.gulimall.ware.entity.WareSkuEntity;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * 商品库存
 *
 * @author wanghaochen
 * @email angaoen@outlook.com
 * @date 2022-03-05 00:09:03
 */
@Mapper
public interface WareSkuDao extends BaseMapper<WareSkuEntity> {

    /**
     * 根据skuId和wareId更新库存
     *
     * @param skuId  商品Id
     * @param wareId 仓库id
     * @param skuNum 商品数量
     */
    void updateStockBySkuIdAndWareId(@Param("skuId") Long skuId,
                                     @Param("wareId") Long wareId,
                                     @Param("skuNum") Integer skuNum);

    /**
     * 获取对应商品是否有库存
     *
     * @param skuIds 商品id列表
     * @return 返回结果
     */
    List<SkuHasStockVo> listHasStockBySkuIds(@Param("skuIds") List<Long> skuIds);

    /**
     * 解锁库存
     *
     * @param skuId  skuId
     * @param skuNum 解锁数量
     * @param wareId 仓库id
     */
    int unlockStock(@Param("skuId") Long skuId, @Param("skuNum") Integer skuNum, @Param("wareId") Long wareId);
}
